<!doctype html>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="resources/helpers.js"></script>

<script>
promise_test(async t => {
  let start_length = navigation.entries().length;
  let start_index = navigation.currentEntry.index;
  // Wait for after the load event so that the navigation doesn't get converted
  // into a replace navigation.
  await new Promise(resolve => window.onload = () => t.step_timeout(resolve, 0));

  let result2;
  navigation.onnavigate = t.step_func(e => {
    if (e.info == 1) {
      result2 = navigation.navigate("#2", { info: 2 });
      assert_true(e.defaultPrevented);
    }
  });

  const result1 = navigation.navigate("#1", { info: 1 });

  assert_equals(navigation.entries().length, start_length + 1);
  assert_array_equals(navigation.entries().slice(start_index).map(e => (new URL(e.url)).hash), ["", "#2"]);

  await assertBothRejectDOM(t, result1, "AbortError");
  await assertBothFulfill(t, result2, navigation.currentEntry);
}, "if navigate() is called inside onnavigate, the previous navigation and navigate event are cancelled");
</script>
